#include <bits/stdc++.h>
using namespace std;
#define int long long
void solve()
{
    int n,m;
    cin>>n>>m;
    vector<vector<int>> v(n+1,vector<int>(m+1));
    int mx=0,mc=0,mi,mj;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            cin>>v[i][j];
            if(v[i][j]>mx)
            {
                mx=v[i][j];
                mc=1;
                mi=i,mj=j;
            }
            else if(v[i][j]==mx)mc++;
        }
    }
    vector<int> x(n+1),y(m+1);
    int z=0;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            if(v[i][j]==mx)
            {
                ++x[i];
                ++y[j];
            }
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            int f=x[i]+y[j];
            if(v[i][j]==mx)
            {
                f--;
            }
            if(f>z)
            {
                z=f;
                mi=i,mj=j;
            }
        }
    }
    for(int i=1;i<=n;i++)
    {
        v[i][mj]--;
    }
    for(int j=1;j<=m;j++)
    {
        v[mi][j]--;
    }
    v[mi][mj]++;
    mx=0;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            mx=max(mx,v[i][j]);
        }
    }
    cout<<mx<<endl;
}
signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int T=1;
    cin>>T;
    while(T--)
    {
       solve();
    }
    return 0;
}